<template>
  <el-card class="box-card">
    <div slot="header" class="clearfix">
      <span>基本资料</span>
    </div>
<el-form :model="userForm" :rules="userRules" ref="userForm" label-width="100px">
  <el-form-item label="登录名称" prop="name">
    <el-input v-model="userForm.username"></el-input>
  </el-form-item>
  <el-form-item label="用户昵称" prop="nickname">
    <el-input v-model="userForm.nickname"></el-input>
  </el-form-item>
  <el-form-item label="用户邮箱" prop="email">
    <el-input v-model="userForm.email"></el-input>
  </el-form-item>
    <el-form-item>
    <el-button type="primary" @click="submitForm('ruleForm')">提交修改</el-button>
    <el-button @click="resetForm('ruleForm')">重置</el-button>
  </el-form-item>

</el-form>
  </el-card>
</template>

<script>
import { mapState } from 'vuex'
export default {
  name: 'UserInfo',
  data () {
    return {
      userForm: {
        username: '',
        nickname: '',
        email: ''
      },
      userRules: {
        nickname: [
          { required: true, message: '请输入用户昵称', trigger: 'blur' },
          { pattern: /^\S{1,10$/, message: '昵称必须是1~10位的非空字符', trigger: 'blur' }
        ],
        email: [
          { required: true, message: '请输入邮箱', trigger: 'blur' },
          { type: 'email', message: '请输入正确格式的邮箱', trigger: 'blur' }
        ]
      }
    }
  },
  created () {
    this.userForm = this.userInfo
  },
  computed: {
    ...mapState('user', ['userInfo'])
  }
}
</script>

<style lang="less" scoped>
.el-form {
  width: 500px;
}
</style>
